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4. The method claimed in claim 2, further comprising, if a results set 
for a given query Q is non-empty, skipping processing of one or more additional 
queries that are dependent from said query Q in a negative query lattice. 

5. The method claimed in claim 1, wherein a subset of said queries 
comprises queries represented by a common query type, and 

wherein processing of said subset comprises: 

issuing polling queries to a query instance table of said query type for 
each of said updates; and 

designating query instances identified through said polling queries as said 
identified queries. 

6. The method claimed in claim 1, wherein a subset of said queries 
comprises queries represented by a common query type, and 

wherein processing of said subset comprises: 

issuing polling queries to a query instance table of said query type, and to 
update tables constructed from said update log and corresponding to relations 
utilized by queries of said query type, for each of said updates; and 

designating query instances identified through said polling queries as said 
identified queries. 

7. The method claimed in claim 1, wherein a subset of said queries 
comprises queries represented by a common query type and including a join 
operation, and 

wherein processing of said subset comprises: 

issuing polling queries to a query instance table of said query type, and to 
update tables constructed from said update log and corresponding to relations 
utilized by queries of said query type, and to relations of said database utilized 
by queries of said query type for which there have been no updates since the 
preceding invalidation cycle, for each of said updates; and 

designating query instances identified through said polling queries as said 
identified queries. 
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8. In a system for producing dynamically generated content in 
response to user content requests that generate database queries, a method for 
invalidating dynamically generated content stored in caches of network devices, 
comprising: 

receiving updates to a database of the system; 

periodically performing processing on a set of received queries to identify 
queries for which corresponding dynamically generated content will be 
invalidated as a result of said updates; and 

sending invalidation messages to devices storing said corresponding 
content of said identified queries, 

wherein said processing comprises, for a given query Q, 



results set consisting of the results: 

[{R^lIXl Rnew,2 IXl ... N Rnew,n) U ... U (RnewJ IX ... tXl R+j M ... OO Rnew,n) U ... 

U (Rnew,l IXJ ... 1X1 Rnew,n.1 ^ R-'n)] U 

[(R"llXl Rold,2 IXl ... 1X1 RoId,n) U ... U (RoldJ 1X1 ... IXl R-j 1X1 ... M Rold,n) U ... 

U (Rold,l IXl „. M Roid,n-l M R-n)] 

where each Rn is a relation involved in the query Q, each Roid,n is a state of 
the relation Rn as of the beginning of a preceding processing cycle, each 
Rnew,n is 3 State of tho relation Rn as of the beginning of the current 
processing cycle, each Rn is a subset of tuples deleted from the relation 
Rn since the beginning of a preceding processing cycle, and each R^n is a 
subset of tuples added to the relation Rn since the beginning of a 
preceding processing cycle, and 

if said results set is non-empty, designating said query Q as one of 
said identified queries. / 



9. A system for producing dynamically generated content in response 
to user content requests that generate database queries, comprising: 
a database management system; 

a web server for receiving user requests for dynamically generated 
content and for providing said dynamically generated content; and 




whether a results set is empty or non-empty, the 
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an application server coupled between the database management system 
and the web server for generating database polling queries corresponding to said 
requests and for supplying resulting data from the database to said web server, 

the system performing an invalidation method to invalidate dynamically 
generated content generated by said system and stored in caches of network 
devices, said method comprising: 

receiving updates to the database management system; 

periodically performing processing on a set of received queries to identify 
queries for which corresponding dynamically generated content will be 

H invalidated as a result of said updates; and 

O 

Q sending invalidation messages to devices storing said corresponding 

ffl 

^ content of said identified queries, 

p! wherein said processing is performed using a delayed version of said 

Q database that reflects the state of the database at the beginning of a preceding 

p processing cycle, and an update log that reflects all updates since the beginning 

ry 

1^ of the preceding processing cycle. 

m 
m 

ry 10. The system claimed in claim 9, wherein said processing comprises: 

determining whether respective results sets for subsets of said set of 

queries are empty or non-empty for tuples added to and deleted from said 

database between the beginning of a preceding processing cycle and the 

beginning of the current processing cycle; and 

for each non-empty results set, designating the queries of the 

corresponding subset as ones of said identified queries. 

1 1 . The system claimed in claim 10, said processing further 
comprising, if a results set for a given query Q is non-empty, designating as 
identified queries one or more additional queries that are dependent from said 
query Q in a positive query lattice. 

12. The system claimed in claim 10, said processing further 
comprising, if a results set for a given query Q is non-empty, skipping 
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processing of one or more additional queries that are dependent from said query 
Q in a negative query lattice. 

1 3. The system claimed in claim 9, wherein a subset of said queries 
comprises queries represented by a common query type, and 
wherein processing of said subset comprises: 

issuing polling queries to a query instance table of said query type for 
each of said updates; and 

designating query instances identified through said polling queries as said 
identified queries. 

O 

O 14. The system claimed in claim 9, wherein a subset of said queries 

^ comprises queries represented by a common query type, and 
y wherein processing of said subset comprises: 

^ issuing polling queries to a query instance table of said query type, and to 

a 

P update tables constructed from said update log and corresponding to relations 
fy utilized by queries of said query type, for each of said updates; and 

designating query instances identified through said polling queries as said 
identified queries. 

15. The system claimed in claim 9, wherein a subset of said queries 
comprises queries represented by a common query type and including a join 
operation, and 

wherein processing of said subset comprises: 

issuing polling queries to a query instance table of said query type, and to 
update tables constructed from said update log and corresponding to relations 
utilized by queries of said query type, and to relations of said database utilized 
by queries of said query type for which there have been no updates since the 
preceding invalidation cycle, for each of said updates; and 

designating query instances identified through said polling queries as said 
identified queries. 
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16. A system for producing dynannically generated content in response 
to user content requests that generate database queries, comprising: 
a database management system; 

a web server for receiving user requests for dynamically generated 
content and for providing said dynamically generated content; and 

an application server coupled between the database management system 
and the web server for generating database polling queries corresponding to said 
requests and for supplying resulting data from the database to said web server, 

the system performing an invalidation method to invalidate dynamically 
generated content generated by said system and stored in caches of network 
devices, said method comprising: 

receiving updates to the database management system; 
periodically performing processing on a set of received queries to identify 
queries for which corresponding dynamically generated content will be 
invalidated as a result of said updates; and 

sending invalidation messages to devices storing said corresponding 
content of said identified queries, 

wherein said processing comprises, for a given query Q, 



determining whether a results set is empty or non-empty, the 
results set consisting of the results: 

[{R^ltX Rnew,2 X) ... XI Rnew,n) U ... KJ (RnewJ IXI ... N R^j M ... 1X3 Rnew,n) U ... 

KJ (Rnew,l 1X1 ... tX Rnew,n-1 IXI R^n)] U 

[(R lXl Rold,2 1X1 ... M Roid,n) U ... U (Rold,l Xl ... M R-j N ... 1X1 Rold,n) U ... 

U (RoId.1 IXI ... M Ro,d,n-1 IXI R-n)] 

where each Rn is a relation involved in the query Q, each Roid,n is a state of 
the relation Rn as of the beginning of a preceding processing cycle, each 
Rnew,n is 3 State of the relation Rn as of the beginning of the current 
processing cycle, each Rn is a subset of tuples deleted from the relation 
Rn since the beginning of a preceding processing cycle, and each R^n is a 
subset of tuples added to the relation Rn since the beginning of a 
preceding processing cycle, and 

if said results set is non-empty, designating said query Q as one of said 




identified queries 
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17. In a system for producing dynamically generated content in 
response to user content requests that generate database queries, a method for 
Invalidating dynamically generated content stored in caches of network devices, 
comprising: 

receiving updates to a database of the system; 

periodically performing processing on a set of received queries to identify 
queries for which corresponding dynamically generated content will be 
invalidated as a result of said updates; and 

sending invalidation messages to devices storing said corresponding 

1^ 

O content of said identified queries, 

O 

^ wherein said processing is performed using said database, which is 

^ prevented from being updated during said processing so as to reflect the state 

W of the database at the beginning of said processing, and an update log that 

P 

e reflects all updates to the database since the beginning of the preceding 

fy processing cycle. 

m 



m 



18. The method claimed in claim 17, wherein said processing 
comprises: 

determining whether respective results sets for subsets of said set of 
queries are empty or non-empty for tuples added to and deleted from said 
database between the beginning of a preceding processing cycle and the 
beginning of the current processing cycle, using said locked database and said 
update log of said database; and 

for each non-empty results set, designating the queries of the 
corresponding subset as ones of said identified queries. 

19. The method claimed in claim 18, further comprising, if a results set 
for a given query Q is non-empty, designating as identified queries one or more 
additional queries that are dependent from said query Q in a positive query 
lattice. 
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20. The method claimed in claim 18, further comprising, if a results set 
for a given query Q is non-empty, skipping processing of one or more additional 
queries that are dependent from said query Q in a negative query lattice. 

21 . The method claimed in claim 17, wherein a subset of said queries 
comprises queries represented by a common query type, and 

wherein processing of said subset comprises: 

issuing polling queries to a query instance table of said query type for 
each of said updates; and 

designating query instances identified through said polling queries as said 
p identified quenes. 

5 

08 

=P 22. The method claimed in claim 1 7, wherein a subset of said queries 

UJ comprises queries represented by a common query type, and 

O 

g wherein processing of said subset comprises: 

^ issuing polling queries to a query instance table of said query type, and to 

fU update tables constructed from said update log and corresponding to relations 

gi 

p utilized by queries of said query type, for each of said updates; and 
-'"^ designating query instances identified through said polling queries as said 

identified queries. 

23. The method claimed in claim 17, wherein a subset of said queries 
comprises queries represented by a common query type and including a join 
operation, and 

wherein processing of said subset comprises: 

issuing polling queries to a query instance table of said query type, and to 
update tables constructed from said update log and corresponding to relations 
utilized by queries of said query type, and to relations of said database utilized 
by queries of said query type for which there have been no updates since the 
preceding invalidation cycle, for each of said updates; and 

designating query instances identified through said polling queries as said 
identified queries. 
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24. In a system for producing dynamically generated content in 
response to user content requests that generate database queries, a method for 
invalidating dynamically generated content stored in caches of network devices, 
comprising: 

receiving updates to a database of the system; 

periodically performing processing on a set of received queries to identify 
queries for which corresponding dynamically generated content will be 
invalidated as a result of said updates; and 

sending invalidation messages to devices storing said corresponding 
content of said identified queries, 

□ 

p wherein said processing comprises, for a given query Q, 

2 determining whether a results set is empty or non-empty, the 

01 results set consisting of the results: 

y 

D [(R"'llXl Rnew,2 IXI ... IX Rnew,n) U ... U (Rnew,1 ^ ... IXI R**"] IXI ... IX Rnew,n) ... 

= (J (Rnew,1 N ... N N R^)] u 

O 

fU [(R'ltXl (Rnew,2 U R z) ^ ... ^ (Rnew,1 U R l)) U ... ^ ({Rnew,l U R l) ... tXI R j ^ 

pj ... 1X1 (Rnew,n U R n)) U ... U {{RnewJ U R"l) IXI ... IXJ (Rnew,n-1 U R'n-l) IXI R n) 

01 U (Rold,1 tXI ... 1X1 Roid,n-1 IXI R'n)] 

^1 where each Rn is a relation involved in the query Q, each Roid,n is a state of 

the relation Rn as of the beginning of a preceding processing cycle, each 
Rnew,nis 3 State of the relation Rn as of the beginning of the current 
processing cycle, each R n is a subset of tuples deleted from the relation 
Rn since the beginning of a preceding processing cycle, and each R^n is a 
subset of tuples added to the relation Rn since the beginning of a 
preceding processing cycle, and 

if said results set is non-empty, designating the query Q as one of 
said identified queries. 

25. The method claimed in claim 24, wherein said processing further 
comprises adjusting said results set to account for the over-invalidation term: 

IXl"i (Ri R^i) - (IXl"i R-| KJ IXl^i R+i) 
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26. A system for producing dynamically generated content in response 
to user content requests that generate database queries, comprising: 

a database management system; 

a web server for receiving user requests for dynamically generated 
content and for providing said dynamically generated content; and 

an application server coupled between the database management system 
and the web server for generating database polling queries corresponding to said 
requests and for supplying resulting data from the database to said web server, 

the system performing an invalidation method to invalidate dynamically 
generated content generated by said system and stored in caches of network 
devices, said method comprising: 

receiving updates to the database management system; 

periodically performing processing on a set of received queries to identify 
queries for which corresponding dynamically generated content will be 
invalidated as a result of said updates; and 

sending invalidation messages to devices storing said corresponding 
content of said identified queries, 

wherein said processing is performed using said database, which is 
prevented from being updated during said processing so as to reflect the state 
of the database at the beginning of said processing, and an update log that 
reflects all updates to the database since the beginning of the preceding 
processing cycle. 

27. The system claimed in claim 26, wherein said processing 
comprises: 

determining whether respective results sets for subsets of said set of 
queries are empty or non-empty for tuples added to and deleted from said 
database between the beginning of a preceding processing cycle and the 
beginning of the current processing cycle, using said locked database and said 
update log of said database; and 

for each non-empty results set, designating the queries of the 
corresponding subset as ones of said identified queries. 
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28. The system claimed in claim 27, said processing further 
comprising, if a results set for a given query Q is non-empty, designating as 
identified queries one or more additional queries that are dependent from said 
query Q in a positive query lattice. 

29. The system claimed in claim 27, said processing further 
comprising, if a results set for a given query Q is non-empty, skipping 
processing of one or more additional queries that are dependent from said query 
Q in a negative query lattice. 

30. The system claimed in claim 26, wherein a subset of said queries 
comprises queries represented by a common query type, and 

wherein processing of said subset comprises: 

issuing polling queries to a query instance table of said query type for 
each of said updates; and 

designating query instances identified through said polling queries as said 
identified queries. 

31 . The system claimed in claim 26, wherein a subset of said queries 
comprises queries represented by a common query type, and 

wherein processing of said subset comprises: 

issuing polling queries to a query instance table of said query type, and to 
update tables constructed from said update log and corresponding to relations 
utilized by queries of said query type, for each of said updates; and 

designating query instances identified through said polling queries as said 
identified queries. 

32. The system claimed in claim 26, wherein a subset of said queries 
comprises queries represented by a common query type and including a join 
operation, and 

wherein processing of said subset comprises: 
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issuing polling queries to a query instance table of said query type, and to 
update tables constructed from said update log and corresponding to relations 
utilized by queries of said query type, and to relations of said database utilized 
by queries of said query type for which there have been no updates since the 
preceding invalidation cycle, for each of said updates; and 

designating query instances identified through said polling queries as said 
identified queries. 



m 



33. A system for producing dynamically generated content in response 

^ to user content requests that generate database queries, comprising: 

O ■ 

O a database management system; 

^ a web server for receiving user requests for dynamically generated 

yj content and for providing said dynamically generated content; and 

O an application server coupled between the database management system 

a 

and the web server for generating database polling queries corresponding to said 
requests and for supplying resulting data from the database to said web server, 
the system performing an invalidation method to invalidate dynamically 
^ generated content generated by said system and stored in caches of network 
devices, said method comprising: 

receiving updates to the database management system; 
periodically performing processing on a set of received queries to identify 
queries for which corresponding dynamically generated content will be 
invalidated as a result of said updates; and 

sending invalidation messages to devices storing said corresponding 
content of said identified queries, 

wherein said processing comprises, for a given query Q, 

determining whether a results set is empty or non-empty, the 
results set consisting of the results: 

Rnew,2 ^ ... ^ Rnew,n) • . , ^ (Rnew,1 nnew,n) O ... 

<J (Rnew.l N ... M Rnew,n-1 ^ r^)] U 

[(R lN {Rnew.2 U R-2) N ... N (Rnew.l U R l)) W ... U ((Rnew.l U R l) N ... N Rj N 
... N {Rnew.n U Rn)) U ... ({Rnew,1 U R l) N ... tXl{Rnew,n-1 ^ Rn-l) N Rn) 
U (Rold,l N ... 1X1 Rold,n-1 N Rn)] 
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where each Rn is a relation involved in the query Q, each Roid,n is a state of 
the relation Rn as of the beginning of a preceding processing cycle, each 
Rnew.n is a State of the relation Rn as of the beginning of the current 
processing cycle, each R n is a subset of tuples deleted from the relation 
Rn since the beginning of a preceding processing cycle, and each R'^^n is a 
subset of tuples added to the relation Rn since the beginning of a 
preceding processing cycle, and 

if said results set is non-empty, designating the query Q as one of 
said identified queries. 

P 34. The system claimed in claim 33, wherein said processing further 

a comprises adjusting said results set to account for the over-invalidation term: 

ixi"i (R-i u R^i) - (ixi"i Ri ^ ixi"i R^i) 

a 

i 
m 
m 
o 
m 
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35. In a system for producing dynamically generated content in 
response to user content requests that generate database queries, a method for 
invalidating dynamically generated content stored in caches of network devices, 
comprising: 

receiving updates to a database of the system; 

periodically performing processing on a set of received queries to identify 
queries for which corresponding dynamically generated content will be 
invalidated as a result of said updates; and 

sending invalidation messages to devices storing said corresponding 
content of said identified queries, 

a g 

Q wherein said processing is performed using said database, which is freely 

updated during said processing, and a portion of an update log of said database 
that reflects updates to the database made prior to the beginning of said 

y processing. 

O 

S 

g 

ru 



m 



ni 



36. The method claimed in claim 35, wherein said processing 
comprises: 

Q determining whether respective results sets for subsets of said set of 

queries are empty or non-empty for tuples added to and deleted from said 
database since the beginning of a preceding processing cycle, using said freely 
updated database and said locked update log of said database; and 

for each non-empty results set, designating the queries of the 
corresponding subset as ones of said identified queries. 

37. The method claimed in claim 36, further comprising, if a results set 
for a given query Q is non-empty, designating as identified queries one or more 
additional queries that are dependent from said query Q in a positive query 
lattice. 

38. The method claimed in claim 36, further comprising, if a results set 
for a given query Q is non-empty, skipping processing of one or more additional 
queries that are dependent from said query Q in a negative query lattice. 
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39. The method claimed in claim 35, wherein a subset of said queries 
comprises queries represented by a common query type, and 
wherein processing of said subset comprises: 

issuing polling queries to a query instance table of said query type for 
each of said updates; and 

designating query instances identified through said polling queries as said 
identified queries. 

I«a. 40. The method claimed in claim 35, wherein a subset of said queries 

Q comprises queries represented by a common query type, and 
^ wherein processing of said subset comprises: 

ff^ issuing polling queries to a query instance table of said query type, and to 

W 

□ update tables constructed from said update log and corresponding to relations 
p utilized by queries of said query type, for each of said .updates; and 

m 
m 



m 



designating query instances identified through said polling queries as said 
identified queries. 

41 . The method claimed in claim 35, wherein a subset of said queries 
comprises queries represented by a common query type and including a join 
operation, and 

wherein processing of said subset comprises: 

issuing polling queries to a query instance table of said query type, and to 
update tables constructed from said update log and corresponding to relations 
utilized by queries of said query type, and to relations of said database utilized 
by queries of said query type for which there have been no updates since the 
preceding invalidation cycle, for each of said updates; and 

designating query instances identified through said polling queries as said 
identified queries. 

42. The method claimed in claim 35, wherein said processing further 
comprises correcting an under-invalidation of a preceding processing cycle. 
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43, In a system for producing dynamically generated content in 
response to user content requests that generate database queries, a method for 
invalidating dynamically generated content stored in caches of network devices, 
comprising: 

receiving updates to a database of the system; 

periodically performing processing on a set of received queries to identify 
queries for which corresponding dynamically generated content will be 
invalidated as a result of said updates; and 

p sending invalidation messages to devices storing said corresponding 

2 content of said identified queries, 

i wherein said processing comprises, for a given query Q, 



01 

W 
O 



□ 

m 



determining whether a results set is empty or non-empty, the 
results set consisting of the results: 

a 

Q 

nj (R + 1 IX {R'2 U R^2)M ... IXl (R'n U R^n)) KJ... 

rU U {(R'l u R*i)M ... NR+j N ... N (R'n u R-'n )) U... 

^ <(R'l ^ R""!) ^ ■•• ^ (R'n-1 U R^n-l) 1X1 R*n) U 
(R-1 N (R'2 U R-2) 1X1... N (R'n U Rn)) U ... 

U ((R'l U R-i)IXl ... NR-j M ... M (R'n KJ Rn )) <J ... 
W ({R'l U R-l)N ... 1X1 (R'n-i KJ Rn-l) 1X1 Rn) 

where each Rn is a relation involved in the query Q, each R'nj s_a^t3te_of 
the relation Rn as of the time of processing of the query Q, each R n is a 

^ — ■ 

subset of tuples deleted from the relation Rn since the beginning of a 
preceding processing cycle, and each R^n is a subset of tuples added to 
the relation Rn since the beginning of a preceding processing cycle, and 

if said results set is non-empty, designating the query Q as one of 
said identified queries. 



44. A system for producing dynamically generated content in response 
to user content requests that generate database queries, comprising: 
a database management system; 

a web server for receiving user requests for dynamically generated 
content and for providing said dynamically generated content; and 
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an application server coupled between the database management system 
and the web server for generating database polling queries corresponding to said 
requests and for supplying resulting data from the database to said web server, 

the system performing an invalidation method to invalidate dynamically 
generated content generated by said system and stored in caches of network 
devices, said method comprising: 

receiving updates to the database management system; 

periodically performing processing on a set of received queries to identify 
queries for which corresponding dynamically generated content will be 
invalidated as a result of said updates; and 
Q sending invalidation messages to devices storing said corresponding 



5 



SI 

ru 



content of said identified queries, 

wherein said processing is performed using said database, which is freely 



W updated during said processing, and a portion of an update log of said database 

s that reflects updates to the database made prior to the beginning of said 

O 

m processing. 



45. The system claimed in claim 44, wherein said processing 
comprises: 

determining whether respective results sets for subsets of said set of 
queries are empty or non-empty for tuples added to and deleted from said 
database since the beginning of a preceding processing cycle, using said freely 
updated database and said locked update log of said database; and 

for each non-empty results set, designating the queries of the 
corresponding subset as ones of said identified queries. 

46. The system claimed in claim 45, further comprising, if a results set 
for a given query Q is non-empty, designating as identified queries one or more 
additional queries that are dependent from said query Q in a positive query 
lattice. 
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47. The system claimed in claim 45, further comprising, if a results set 
for a given query Q is non-empty, skipping processing of one or more additional 
queries that are dependent from said query Q in a negative query lattice. 

48. The system claimed in claim 44, wherein a subset of said queries 
comprises queries represented by a common query type, and 

wherein processing of said subset comprises: 

issuing polling queries to a query instance table of said query type for 
each of said updates; and 

designating query instances identified through said polling queries as said 
identified queries. 

49. The system claimed in claim 44, wherein a subset of said queries 
comprises queries represented by a common query type, and 

wherein processing of said subset comprises: 

issuing polling queries to a query instance table of said query type, and to 
update tables constructed from said update log and corresponding to relations 
utilized by queries of said query type, for each of said updates; and 

designating query instances identified through said polling queries as said 
identified queries. 

50. The system claimed in claim 44, wherein a subset of said queries 
comprises queries represented by a common query type and including a join 
operation, and 

wherein processing of said subset comprises: 

issuing polling queries to a query instance table of said query type, and to 
update tables constructed from said update log and corresponding to relations 
utilized by queries of said query type, and to relations of said database utilized 
by queries of said query type for which there have been no updates since the 
preceding invalidation cycle, for each of said updates; and 

designating query instances identified through said polling queries as said 
identified queries. 
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51 . The system claimed in claim 44, wherein said processing further 
comprises correcting an under-invalidation of a preceding processing cycle. 

52. A system for producing dynamically generated content in response 
to user content requests that generate database queries, comprising: 

a database management system; 

a web server for receiving user requests for dynamically generated 
content and for providing said dynamically generated content; and 
^ an application server coupled between the database management system 

O and the web server for generating database polling queries corresponding to said 

O 

^ requests and for supplying resulting data from the database to said web server, 

the system performing an invalidation method to invalidate dynamically 
g generated content generated by said system and stored in caches of network 

3 devices, said method comprising: 

O 

py' receiving updates to the database management system; 

periodically performing processing on a set of received queries to identify 
queries for which corresponding dynamically generated content will be 
invalidated as a result of said updates; and 

sending invalidation messages to devices storing said corresponding 
content of said identified queries, 

wherein said processing comprises, for a given query Q, 

determining whether a results set is empty or non-empty, the 
results set consisting of the results: 

(R^ tX3 (R'2 ^ R^2)iXl ... M (R'n U R^n)) U... 

U ((R'l u R^i)lx] ... txiR^i ixi ... M (R'n U R^n )) u... 
u ((R'l u R^i) 1X1 ... IXI (RVi u R-'n-i) IXI R-'n) u 

(R-1 tXl (R'2 U R-2) tX].., N (R'n U Rn)) U ... 

^ ((R'l u R"i)!Xl ... IXiR-j N ... 1X1 (R'n yj Rn )) ^ ... 

U ((R'l U R-l)!X^ ... ^ (R'n-1 U Rn-l) 1X1 Rn) 

where each Rn is a relation involved in the query Q, each R'n is a state of 
the relation Rn as of the time of processing of the query Q, each R n is a 
subset of tuples deleted from the relation Rn since the beginning of a 
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preceding processing cycle, and each R^n Is a subset of tuples added to 
the relation Rn since the beginning of a preceding processing cycle, and 

If said results set is non-empty, designating the query Q as one of 
said Identified queries. 
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